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(54) Multi-stage message channel switch 

(57) The invention relates to a multi-stage message 
channel switch conrprising for exchanging communica- 
tion data between a given number of incoming terminals 
and a given number of outgoing terminals. 

This switch comprises a first stage including a plu- 
rality of unit switches (primary switches) each having an 
integral number m of incoming lines, an integral number 
C of outgoing lines and the ratio of 1 to x between the 
incoming line speed and the outgoing line speed, 

a middle stage including a plurality of unit switches 
(secondary switches) each having an integral 
number k of incoming lines and an integral number 
Is of outgoing lines, and the ratio of 1 to 1 between 
the incoming tine speed and the outgoing line 
speed, and 

a final stage including a plurality of unit switches 
(tertiary switches) each having an integral number r 
of incoming lines, an integral number m of outgoing 
lines, and the ratio of x to 1 between the incoming 
line speed and the outgoing line speed. 



the primary switches being in the number of k> 

the secondary switches in the number of l and 
the tertiary switches being in the number of k. 
the r outgoing lines of the primary switches being 
connected to the secondary switches respectively, 
the k outgoing lines of the secondary switches 
being connected to the tertiary switches, respec- 
tively, the relationship 

r 2: 2 X { ^(in-l)/(x-l) - lp+ l. 



(the symbol 



>-(m-l)/(x.l)T 



indicates the minimum integral number equal to or 
larger than (m-1)/(x-1) ) being held. 
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Description 

The invention relates to a multi-stage message 
channel switch according to claim 1 . 

A conventional non-blocking multi-channei switch of s 
Clos type is well known for circuit switch. (See Akimaru: 
"Outline of Current Exchange Engineering" published 
by Ohm. 1979. pp. 136 to 137. and C. Clos: A Study of 
Non Blocking Networks. Bell System Technical Journal 
Vol. 32. Na 3 (1953)). io 

A Clos-type nruitti-stage switch is assumed to have 
a number m of incoming lines of a primary switch, a 
number r of outgoing lines thereof, a number k of the 
incoming and outgoing lines respectively of a secondary 
switch, a number r of incoming lines of the tertiary is 
switch and a number m of outgoing lines thereof, a 
number k of the primary switches, a number r of the sec- 
ondary switches, and a number k of the tertiary 
switches, so configured that one each of the r outgoing 
lines of the primary switdi is connected to each of the 20 
secondary switches, and one each of the k outgoing 
lines of the secondary switch to each of the tertiary 
switches. This multi-stage switch construction thus has 
three stages to satisfy the relationship r ^ 2m - 1 
(CIos's formula). 2s 

The "non-blocking'* is defined to indicate that if both 
the incoming and outgoing lines of a switch have an 
empty capacity, there always exists a bus connecting 
them. 

The Clos-type switch is "non-blocking" if it handles 30 
a plurality of calls of a single speed. In the case where 
each of the calls has a given speed, however, the oper- 
ating efficiency of the link connecting the unit switches 
is reduced, and therefore the switch is not "non-block- 
ing". If respective calls are different in speed, a call of 3S 
low speed may, for example, occupy a part of the link 
capacity, so that in spite of some empty capacity of the 
link, a high-speed call may not enter there. Due to this 
what is called a "decayed phenomenon", the link oper- 
ating efficiency is reduced, and therefore a blocking 4C 
occurs even though CIos's equation may be satisfied. 

It is an object of the present invention to provide a 
multi-stage message channel switch of non-blocking 
exchange which switch can be realized with minimum 
construction reqirements. This object is achieved by a 45 
multi-stage message channel switch. 

This problem is solved by increasing the links of the 
multi-stage switch spatially, that is, by Increasing not 
only the number of the links but also the "timing" thereof 
with an increased link speed. Specifically, although the so 
number of incoming and outgoing lines and links are 
assumed to be m and i respectively, a switch configura- 
tion is such that if the speed of the incoming and outgo- 
ing lines is assumed to be unity, the link speed is x times 
higher to satisfy the relationship r a 2 x {(m-1)/(x-1)} ss 
- 1 . 

In this equation, (m-1) on the right side indicates 
the state in which (m-1 ) of m incoming lines are busy, (x- 
1), on the other hand, is the link speed ratio x, less the 



unity representing the incoming line speed ratio, indicat- 
ing a limit value of A 0 in a state of (x-I^A) where a 
given link is busy except for a capacity short of a very 
small amount ^ in a single incoming line in terms of 
speed. 
Thus, 

^(m-l)/(x-ir 

indicates the number of links in state that in spite of a 
certain empty capacity in the link, a single inconrting line 
cannot be accommodated, that is, a state where each 
link is used most inefficiently. The symbol [a] indicates a 
minimum integral number over a. It is thus seen that a 
number 

{ '•(m-l)/(x-l)T . 1} 

of links except for one are in such a state for both outgo- 
ing and incoming lines. Therefore, when the number of 
links twice as many that is, 

2 X { ^(m-l)/(x-l)^ . 1}, 

one new incoming line cannot be accommodated in the 
links, and if there is another accommodatable link, that 
is. and if number is 

2 X { --(in-D/Cx-Dl - 1} + 1. 

both the incoming line side (primary link) and the outgo- 
ing line side (secondary link) have a link sharing an 
enrpty capacity of at least one channel of incoming line. 

Thus, if the number r of the links satisfies the rela- 
tions 

r St 2 X { '•(m- l)/(x.l) - IP + U 



this switch will never block. 

Rg. 1 and 2 are diagrams for explaining an embod- 
iment of the present invention. 

Rg. 3 is a functional block diagram showing an unit 
switch used with the present invention. 

Rg. 4A to 4C are diagrams for explaining a cell con- 
struction used in the unit switch of Rg. 3. 

Rg. 5 is a detailed functional block diagram show- 
ing and address pointer included in Rg. 3. 

Rg. 6 is a diagram for explaining the operation of a 
series-parallel conversion multiplexer included in Rg. 3. 

Rg. 7 is a detailed functional block diagram show- 
ing an idle address FIFO included in Fig. 3. 

Rg. 8 is a functional block diagram showing another 
unit switch construction. 



3 



BNSOOCIO: <EP_0778719A2J_> 




EP0 778 



Rg. 9 is a diagram for explaining the logics of the 
read access control in Rg. 8. 

Rg. 10 is a functional block diagram showing stil! 
another unit switch construction. 

Rg. 11 is a diagram for explaining a cell construe- s 
tion used in the ennbodiment of Rg. 1 0. 

Rg. 12 is a functional block diagram showing still 
another unit switch constaiction. 

Rg. 13 is a detailed functional block diagram show- 
ing address FIFOs included in Rg. 12. 

Rg. 14 is a functional block diagram showing still 
another unit switch construction. 

Rg. 15 is a'detailed functional block diagram show- 
ing address FIFOs included in Rg. 14. 

An embodiment of the present invention will be is 
explained below with reference to Rg. 1. As shown in 
Fig. 1. the number n of incoming and outgoing lines is 
given as n = mk . A number k of unit switches with a 
number m of input terminals and a number (2m - 3) of 
output terminals are arranged as first-stage switches. 20 
On the other hand, intermediate-stage switches include 
a number (2m - 3) unit switches with a nunnber js of input 
and output terminals, and final-stage switches a number 
k of unit switches with a number (2m - 3) Input terminals 
and a number m of output terminals. As shown in Rg. 1 . 2S 
the respective unit switches are connected to each 
other in such a way that the unit switches making up the 
first-stage switches are connected to all the unit 
switches of intermediate stage, and those making up 
the intermediate stage to all the unit switches making up so 
the final stage. In the above-mentioned equation for 
non-bloc*dng conditions, 

r > 2 X { '■(m-l)/(x-l) - 1} + 1, 

the embodimerrt under consideration is associated with 
a case in which x = 2 and r = 2m - 3 , satisfying an 
equality. 

The unit switches in each stage may be made up of 40 
those explained with reference to Figs. 8 and 10 or Rgs. 
12 and 14. 

Now, another embodiment of the multi-stage mes- 
sage channel switch is shown in Rg. 2. Unlike in the 
embodiment in Fig. 1 in which x = 2 and r = 2m - 3 in 45 
the above-mentioned equation for non-blocking condi- 
tions 

^ r ^ 2 X { ^(m-l)/(x-l) - 1} + 1, ^ 

the embodiment under consideration is associated with 
a case in which x = 3 and r = m - 2 . In this case. too. an 
equality is satisfied- The same approach to the configu- 
ration may apply as in Fig. 1 . The configuration of unit ss 
switches is also similar to that of the first embodiment in 
spedfic points and therefore will not be explained more 
in detail. 

According to these embodiments, a multi-stage 



A2 




switch capable of non-blocking exchange is realized 
with the required minimum construction requirements. 

An embodiment of an unit switch will be explained 
with reference to Fig. 3. In Rg. 3. a number q of incom- 
ing lines are connected through a series-parallel con- 
version multiplexer 101 to a data input (Dl) of a main 
buffer 105. The data output (DO) of the main buffer 105 
is connected to a parallel-series conversion multiplex 
separator and is separated into a number m of outgoing 
lines. The output portion of the series-parallel conver- 
sion multiplexer 101 which corresponds to the cell 
header is connected to a read address terminal (RA) of 
a header conversion table 102. The data output (DO) 
portion of the header conversion table 102 which con-e- 
sponds to a new header, on the other hand, is con- 
nected to tiie data input of the main buffer 105, tiie 
portion thereof corresponding to an emptyybusy data (0 
for empty) connected through an AND gate 109 to a 
write enable input (WE) of the main buffer 105. and the 
outgoing number portion thereof connected to a desti- 
nation outgoing number input (DEST) of an address 
pointer 104. The data input (Dl) and the write address 
(WA) of the header conversion table 102 are connected 
to a control system not shown. The data output (DO) of 
the idle address FIFO 103 is the data input (Dl) of the 
main buffer 105 and connected to tiie next write address 
(NWAD) of the address pointer 104. The empty indica- 
tion output (EPTY) is connected to the write enable 
input (WE) of the main buffer 105 through the AND gate 
109. The write address output (WAD) of the address 
pointer 1 04 is connected to tine write address input (WA) 
of the main buffer 105. The read address output (RAD), 
on the other hand, is connected through a selector 110 
to the read address output (RA) of the main buffer 105 
and the data input (Dl) of the idle address FIFO 103. 
The portion of the data output (DO) of tine main buffer 
105 corresponding to the next read address is con- 
nected to tiie next read address input (NRAD) of the 
address pointer 104, and the other portions tiiereof, that 
is. those portions corresponding to the cell body, are 
separated through the parallel-series conversion multi- 
plex separator 106 into each outgoing line. The output 
of the control counter 107 is connected to the input of 
tiie selector 110. The cue state indication output (STS) 
of the address pointer 104 is connected to both the 
selection input of the selector 110 and the write enable 
input (WE) of tiie idle address FIFO 103 at the same 
time. 

Rrst tiie write operation of the cell into the main 
buffer will be explained. 

The cells that have arrived from respective incom- 
ing lines are subjected to series-to-parallel conversion 
at ttie series-parallel conversion multiplexer 101 to facil- 
itate the handling of each cell separately. An example of 
the construction of the cell arriving from the incoming 
lines is shown in Fig. 4A, and the concept of tiie series- 
parallel conversion multiplexing in Fig. 6. The series- 
parallel conversion multiplexer is generally made up of a 
well-known circuit called "the ban-el shifter". As shown in 
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Rg. 4A, the cell header carries a logic channel number 
written thereon, whereby the header conversion table 

1 02 is accessed to obtain the data as to whether the cell 
of a new logic channel number on the outgoing line side 
Is empty or occupied and a cell destination outgoing line 
number These data ware written in the table with the 
access from the control system at the time of setting a 
call. Rg. 4B shows an exanriple of the output of the 
header conversion table 102. 

The ceil destination outgoing line number is applied 
to the address pointer 104« and an appropriate write 
address is obtained accordingly. The write address is 
obtained accordingly. The write address is applied in 
advance from the idle address FIFO 103. The cell is 
written into the main buffer 105 by use of the same write 
address. If the cell is empty or the idle address FIFO is 
empty (that is. the main buffer has no empty address), 
the output of the AND gate 109 is X^ and therefore no 
data is written in the main buffer 105. At the same time, 
the read clock (RCK) of the idle address FIFO is also "L" 
so that the no output of the empty address is produced. 

Now. the read operation will be explained. The cell 
is read In such a manner in accordance with the number 
generated by the control counter 107. a read address is 
obtained from the address pointer 104 and is used as a 
read address of the main buffer. The value of the control 
counter con-esponds to the outgoing line number. Spe- 
cifically, cells are read one by one sequentially for each 
outgoing line. The address used as a read address is 
applied to the data input (Dl) of the idle address FIFO 

103 and is used again as a write address. If there is no 
cell addressed to a given outgoing line in the main 
buffer, a cue state indication output (STS) is produced, 
so that an address stored in the empty cell address reg- 
ister 1 1 1 is selected as a read address of the main 
buffer 105 by the selector 110. The data in the main 
buffer corresponding to this address is always kept as 
an empty ceil. 

The data output of the idle address FIFO is stored 
In the main buffer together with the cell. This is to indi- 
cate the storage address of the next cell at the same 
destination as the cell destination outgoing line. A 
detailed operation will be explained below with refer- 
ence to Fig. 5. The cell construction in the main buffer is 
shown in Fig. 4C. 

Now, the configuration and operation of the address 
pointer 104 will be explained with reference to Rg. 5. 
The outgoing number Input (DEST) Is connected to the 
irput of the outgoing line number decoder 301 and the 
selection input of the address selector 308. A number m 
of decode outputs of the outgoing number decoder 301 
are connected respectively to the clock Inputs of a 
number m of write registers (WRi to m) 302 to 303. The 
next write address (NWAD) applied from an external 
Idle address FIFO is connected to the input of each 
write register, and the output of each write register pro- 
duced as a write address output (WAD) through the 
write address selector 308. The control counter input 
(RACNT). on the other hand, Is connected to the 



decoder 31 1 and the selection input of the read address 
selector 309. A number m of decode outputs of the 
decoder 31 1 are connected as clock inputs of a number 
m of the read register (RR, ^ ^) respectively through a 

5 gate. The next read address input (NRAD) from an 
external source Is connected to the input of each read 
register, the output of which makes up a read address 
(RAD) through the read address selector 309. Non- 
coincidence detectors 306 and 307 are supplied with 

10 outputs of corresponding write register and read regis- 
ter respectively, the outputs of which make up a cue 
state Indication output (STS) through a non-coincidence 
data selector 130. The outputs of the non-coincidence 
detectors, on the other hand, are also connected to one 

75 of the inputs of the gate. 

The portions of a number m of outputs of the write 
register corresponding to the outgoing lines thereof are 
selected by the write address selector 308 In response 
to the outgoing line number input (DEST) thereby to 

20 make up an address output (WAD). In the process, a 
corresponding value held in the write register by the 
decode output of the outgoing line number decoder 301 
is updated to the value (NWAD) supplied from the idle 
address FIFO. As a result, the NWAD value immediately 

2S before being updated corresponds to the write address 
for the next-arriving cell of the same address as the des- 
tination outgoing line number of the cell to be just writ- 
ten. If this NWAD value is stored in the main buffer 
together with the cell about to be just. written, therefore. 

30 ft is possible to know, when this ceil is read out, from 
which address the next cell destinea tc :he same outgo- 
ing line is to be read. In reading a ceii, a reac register 
output is selected by a read address selector wilh the 
value held In the register is produced as a read address 

35 output (RAD). This output Is thus used as a read 
address output. At the same time, the value held in the 
read register selected is updated by the output of the 
decoder 31 1. The input of the read register involved is 
the next read address stored together with the cell at the 

40 time of write operation which Is read out of the main 
buffer, and therefore the address of the next cell des- 
tined to the same outgoing line can be held in the read 
register 

Rg. 7 shows a configuration of the idle address 
45 FIFO 103. The idle address FIFO 103 Includes a mem- 
ory 501. a write counter (WCNT) 502. a read counter 
(RCNT) 503 and a coincidence detector 504. The write 
counter 502 is a ring counter for producing a write 
address (WA) and counting the same number as the 
50 addresses of the memory 501 . The read counter 503 is 
for producing a read address (RA) and makes up a ring 
counter for counting the same number as the addresses 
of the memory 501. When the values of these two 
counters coincide with each other, it indicates the mem- 
55 ory is ennpty. This condition Is detected by the coinci- 
dence detector 504 to produce an empty output (EPTY). 
In this way. this circuit has the same function as a FIFO 
as a whole. 

Now. another embodiment of an unit switch will be 
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explained with reference to Fig. 8. The switching system 
shown in Fig. 8 operates basically on the same principle 
as the one shown in Rg. 3. In addition, however, the 
system in Rg. 8 has a preferential control mechanism. 
In Rg. 8, the component parts identical to those in Rg. s 
3 are denoted by the same reference numerals as in 
Rg. 3 respectively and will not be described again. The 
emt)odiment of Rg. 8 is different from that of Rg. 3 most 
conspicuously in that the embodiment of Fig, 8 has a 
plurality of address pointers. It is assumed that there are w 
three preferential dasses called class 1(C1), class 
2(C2) and class 3(C3). 

The output of the header conversion table 102 in 
Rg. 8 includes a class indication. The class indication 
output is connected to the input of the dass decoder is 
(CDEC) 605 and the selection input of the write class 
selector (WSEL) 806. Each decoder output of the class 
decoder (CDEC) 605 is connected to the write address 
enable input (WAEN) of the address pointer of each cor- 
responding class. Of the decoder outputs of the class 20 
decoder (CDEC) 605. the output C2 is changed into C2' 
through an AND gate supplied with the output of the up- 
down counter 608. The outputs C1. C3 of the class 
decoder (CDEC) 605 and the OR output of C2* are con- 
nected to the write enable (WE) of the main buffer 105, 2S 
Each cue state indication output (STS) of the address 
points corrasDonding to each class induding the 
addr?=ss pointer (dass 1) 601 » address pointer (class 2) 
602. ^nd the address points (class 3) 603 is connected 
to the nput the }Bxt access control 604. The relation- 30 
ship "^etwe n the iput and output of the read access 
contrci is s xwn. for example, in Fig. 9. The output of 
the read access control 604 is connected to the input of 
the read class selector (RSEL) 607 and the decoder 
(REDEC) 609. The decode output of the decoder 3s 
(REDEC) 609 is connected to the read address enable 
input (RAEN) of the address pointer of a con-esponding 
class on the one hand and a logical sum of the decode 
outputs is connected to the write enable input (WE) of 
the idle address FIFO on the other hand. The up-down 40 
courrter 608 is supplied with tine read address enable 
input (RAEN) of class 2 as an up input and C2' as a 
down input. The classes are so defined that dass 1 is 
small in delay time with a low cell loss rate, class small 
in delay time with some-what large cell loss rate, and 4S 
class 3 somewhat long in delay time with small cell loss 
rate. Class 2. in spite of a somewhat larger cell loss rate, 
is superior to otiier classes, and tiierefore limits the usa- 
ble capacity of a main buffer. Specifically the capacity 
usable for the up-down counter 608 is set by conversion so 
in the number of cells. The up-down counter 608 is dec- 
remented by write and incremented by read when this 
counter becomes zero, therefore, it indicates that the 
main buffer is used to the limit. Under this condition, the 
output C2' becomes "L" and no new write occurs for this ss 
class. As a result, the class 2 cell that has an-ived is dis- 
carded. On tiie other hand, the read priority order is set 
by the read access control in such a manner that the 
class 1 has the least delay time and the class 3 the larg- 




est. Specifically the operation is performed for each 
outgoing line in such a way that if tiie class 1 cell is in 
the main buffer, it is read in the first place, and when the 
dass 1 cue disappears, the dass 2 cell is read out With 
the disappearance of the class 2 cue. the class 3 cell is 
read out. 

With tiie arrival of a cell, tiie class to which tiie par- 
ticular cell belong is identifiable by the output of tiie 
header conversion table 102. so that the write address 
enable output (WAEN) is applied to tiie address pointer 
corresponding to the particular class by tiie dass 
decoder 605. The write address output (WAD) pro- 
duced from tiie address pointer, on the other hand, is 
selected by the write dass selector (WSEL) 606 and is 
used as a write address (WA) for the main buffer. In read 
operation, by contrast, as mentioned earlier, the read 
access control 604 monitors a waiting cue correspond- 
ing to each outgoing line of each class, and effect con- 
ti-ol to assure that outputs are in the order of priority 
among the waiting cues. Specifically, the decode output 
of tiie decoder 609 designates an address pointer of tiie 
dass to be read, and the read class selector 607 selects 
a read address output produced from tiie address 
pointer of tiie class to be read, thus determining the 
read address of the main buffer. 

Now. anotiier embodiment of an unit switch will be 
explained with reference to Fig. 10. The configuration of 
Fig. 10 is free of the header conversion table 102 in Rg. 
3. In tiie case under consideration, the construction of 
tiie cell arriving from the incoming line is shown in Fig. 
1 1. This configuration is suitable for tiie case in which a 
header conversion table is induded for each incoming 
line in the front stage of tiie switch. This configuration 
also has an advantage ttiat in a multi-stage construction 
mentioned later, the header conversion may be ren- 
dered collectively in advance without respective header 
conversion by switches in the respective stages. 

In each of tiie embodiment explained above, tiie 
main buffer and tiie idle address FIFO, or the main 
buffer, idle address FIFO and the address pointer may 
be formed in integrated circuits on the same chip. Then, 
a compact switch and a multi-stage construction 
described above are realized. 

Now. still another embodiment of unit switches will 
be explained with reference to Fig. 12. In Fig. 12, the 
configuration is the same as that in Fig. 3 except for 
address FIFOs 1201. tiie only difference being in con- 
nections. In tiie embodiment of Fig. 12. the data output 
(DO) of tiie idle address FIFO 103 is directiy connected 
to ttie write address (WA) of the main buffer 105. The 
main buffer 105 is written only witti the cell txxly. but not 
with tiie next address data. The address FIFOs 1201 
making up a point of tiiis configuration will be explained 
with reference to Fig. 13. 

The outgoing line number input (DEST) is con- 
nected to tiie outgoing line number decoder (WDEC) 
1301 . and tiie m decoder outputs tiiereof connected to 
tiie write signal inputs (WCK) of a number m of FIFO 
buffers 1303 to 1304. The data input of the FIFO buffers 
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1303 to 1304 make up the data outfxit of the idle 
address FIFO in Rg. 12. The data output of the FIFO 
buffers 1303 to 1304 make up a read address output 
(RAD) through the read address selector 1305. The 
read address selector 1 305 uses a control counter input s 
(RACNT) as a selection input The control counter input 
(RACNT) is further connected to the input of the read 
sequence decoder 1302 and the selection input of the 
empty state selector (EPSEL) 1306. The decode output 
of the read sequence decoder 1 302 is connected to the io 
read signal (RCK) input of each FIFO buffer. The empty 
state signal (EP) of each FIFO buffer makes up a cue 
state indication output (STS) through empty state selec- 
tor (EPSEL), 

In this embodiment, at the time of writing a cell, an is 
empty address from the idle address FIFO is taken out. 
and used as the write address of the main buffer as it is. 
At the same time, the same address is written in the 
FIFO buffer corresponding to the cell destination outgo- 
ing line number in the address FIFOs 1201 . At the time 20 
of reading, on the other hand, addresses are taken out 
sequentially from the FIFO buffers, and with these 
addresses as read addresses, the cells are read out of 
the main buffer. When the FIFO buffers are empty, an 
EP output is produced. 25 

In this configuration, the bufferable number of cells 
for each outgoing line is limited by the capacity of the 
FIFO buffers in the address FIFOs. If this capacity is set 
to a sufficiently large value, however, this configuration 
is simple as a whole. 30 
Rg. 14 shows the configuration of Fig. 12 having a pref- 
erential control mechanism added thereto. The data 
output of the header conversion table 102 has a class 
indication output, which is connected to the class input 
(CLS) of the address FIFOs 1 601 . 35 

Fig. 15 is a diagram showing a corrfiguration of the 
address FIFOs with the preferential control function. 
The component part included in this diagram which are 
similar to those in Fig. 13 are not explained. According 
to the embodiment under consideration, there are two 40 
classes of reading order, preferential and non-preferen- 
tial. Thus, there are two FIFO buffers (such as 1702 and 
1704) for each outgoing line. The write signal input 
(WCK) of the FIFO buffer is a logical product of the 
decoder output of the outgoing line number decoder 4S 
1 301 and that of the class data decoder 1 701 . The read 
signal input (RCK). on the other hand, is the logical 
product of the decode output of the read sequence 
decoder 1302 and the empty state indication output 
(EP) of each FIFO. According to this configuration, at so 
the time of writing a cell, the write address (WAD) is 
stored in a FIFO buffer associated with the outgoing line 
number and class thereof, while at the time of reading a 
cell, the read address is always produced from the FIFO 
on this side until the FIFO on preferential read side ss 
(such as 1702) becomes empty. And only after this 
FIFO becomes empty, the other FIFO (such as 1 704) is 
read. 

This embodiment has two classes of order of prior- 



ity relating to the delay time. Instead, the FIFO t>uffers 
may be increased for each class to meet a multiplicity of 
dasses. Also, the requirement for classification accord- 
ing to loss rate may be satisfied by controlling the 
capacity of the FIFO buffers. 

It will thus be understood that according to the 
present invention there occurs no loss of a cell which 
otherwise might be caused when a new cell is read 
before a cell is read out of the main buffer. Also, all the 
areas of the main buffer may be used for all outgoing 
lines in common, and therefore the memory capacity is 
usable with high efficiency even if cell destinations are 
concentrated on a specific outgoing line. As a result, 
cells are not hardly discarded. This fact is especially 
advantageous in communications of strong burst char- 
acteristic in which cells of the same destinations arrive 
at a given moment. 

Further, the present invention relates to the follow- 
ing: 

1. A switching system comprising a plurality of 
fixed-length cells each including a header section 
and a data section for exchanging communication 
message between a plurality of incoming highways 
and a plurality of outgoing highways on the basis of 
the data contained in the header section, in which a 
plurality of incoming highways are multiplexed in 
time division, cells that arrive are written in memory 
means 105, the cells thus stored are read out] sep- 
arated in multiplex ways and distributed among a 
plurality of outgoing highways thereby to perform 
the switching and buffering operations, said switch- 
ing system further comprising second memory 
means 1 03 for storing an empty address for the first 
memory means 105. and means 104 for controlling 
the write and read into said first memory means 
105 in accordance with the empty address data 
stored in the second memory means. 

2. A switching system comprising a plurality of 
fixed-length cells each including a header section 
and a data section for exchanging communication 
message between a plurality of incoming highways 
and a plurality of outgoing highways on the basis of 
the data contained in the header section, in which a 
plurality of incoming highways are multiplexed in 
time division, the cells that arrive are written in a 
buffer memory (hereinafter referred to as "the main 
buffer") 105, and the cells thus written are read out 

• in an appropriate order, separated in multiplex ways 
and distributed among a plurality of outgoing high- 
ways thereby to perform the switching and buffering 
operations, said switching system further compris- 
ing a FIFO (First In First Out) buffer 103 for storing 
an empty address of the main buffer 105 and 
means 104 for controlling the write and read opera- 
tion of the main buffer 105. the empty idle address 
being retrieved out of the data output of the idle 
address FIFO buffer at the time of writing the cell 
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into the main buffer 105. the read address being 
returned to the data input of the Idle address FIFO 
buffer 103 at the time of reading the cell from the 
main buffer 105. 

5 

3. A s«vitching system according to section 2. 
wherein the control means 104 includes the func- 
tion of controlling the written addresses of the main 
buffer 105 by the destination outgoing highway of 
the particular cell thereby to read out a cett desig- io 
nated to a given outgoing highway as desired. 

4. A switching system according to section 2. 
wherein a memory capable of random input and 
random output is used as said main buffer 105. is 

5. A switching system according to section 2. 
wherein the control means includes two types of 
registers (write and read registers) in the same 
number as the outgoing highways corresponding to so 
the respective outgoing highways, the data output 

of the idle address FIFO buffer 103 is connected to 
the input terminals of the write registers WRvm and 
the data input terminal Dl of the main buffer 105 
respectively, the output terminals of the plurality of 25 
write registers WR^.^ are connected to the write 
address terminal of the main buffer 103 through a 
selector 110 with a selection Input as the destina- 
tion outgoing highway number of an arriving cell, 
the same address of the main buffer 103 being writ- 30 
ten with an arriving ceil of an address and the next- 
arriving cell of the same destination as the first cell 
of the next address as a set at the time of writing a 
cell into the buffer memory 105. said next address 
being used to update the write register correspond- 3s 
ing to the outgoing highway maldng up the destina- 
tion of the particular cell, the data output terminals 
of the main buffer 105 being connected to the input 
terminals of the respective read registers RRi.m. 
the output terminals of the plurality of read registers 4o 
RRi.m being connected to the read address termi- 
nals of the main buffer 105 through a selector 110 
with a selection input as the counter output for gen- 
erating a read timing for each outgoing highway on 
the one hand and to the data input of the idle 45 
address FIFO on the other, the set of the cell and 
the next address being read and the read register 
RRj associated with the highway being updated by 
the next address at the time of reading the cell from 
' the main buffer 105, thereby switching the cells and so 
buffering in chain for each destination outgoing 
highway 

6. A switching system according to section 2, 
wherein each arriving cell bears a dass for identify- ss 
ing the handling conditions, different classes repre- 
senting different cell discarding rates guaranteed by 

the switch, the switching system further comprising 
an up-down counter 608 for counting down when a 
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specified class of cell is written in the main buffer 
^ 105, said counter 608 being counted up when said 
cell is read out. the cells of the same class being 
prohibited from being written into the main buffer 
105 and the cell discarded upon detection that the 
count of the up-down counter 608 becomes zero, 

7. A switching system according to section 5. 
wherein an-iving ceils bear classes for identifying 
the handling conditions, different classes repre- 
senting different delay due to the cell buffering 
guaranteed by the switch, the switching system fur- 
ther comprising a plurality of sets each including a 
write register and a read register, said sets (referred 
to as "the address pointers 104^ being in the same 
number as the classes, said write and read regis- 
ters being in the same numbers as the high-ways, 
means 605 selecting an address pointer 104 to be 
used for the class assigned to a particular cell when 
the cell is written in the main buffer 105. means 609 
for producing a read address by selecting an 
address pointer 601. 602, 603 of the class most 
severe against the delay time when the cell Is read 
out. and means 604 detecting the presence or 
absence of a waiting cue for a cell associated with 
a given outgoing highway of the same class and 
selecting the next most severe class of the address 
pointer In the absence of a waiting cue. 

8. A circuit component part for a switching system 
according to section 2. wherein the main buffer 105 
and the idle address FIFO 103 are mounted In the 
same chip. 

9. A circuit component part for a switching system 
according to section 2, wherein the main buffer 105, 
the idle address FIFO 103 and the control means 
104 are mounted in the same chip- 

10. A switching system according to section 2. com- 
prising FIFO buffers (referred to as "the ^dress 
FFiFOs"*) in the same number as the highways, in 
which the data output of the idle address FIFO 
buffer 103 for storing an empty address of the main 
buffer 105 is connected to the input terminals of a 
plurality of the address FIFOs and the write address 
input of the main buffer WA. the output terminals of 
the address FIFOs DO being connected to the data 
input of the idle address FIFO buffer 103 and the 
read address terminal of the main buffer 105 
through a selector 1305 with a control counter out- 
put as a selection output 

11. A switching system according to section 10. 
wherein each of the arriving cells has a class for 
identifying the handling conditions, different classes 
having different delay times due to the cell buffering 
guaranteed by the switch, the switching system 
comprising a plurality of address FIFOs in the same 
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number as the classes for each outgoing highway, 
means 1701 for selecting an idle FIFO according to 
the dass associated with a cell at the time of writing 
the cell in the main buffer 105. and means 1706 to 
1707 for producing a read address by selecting an 
address FIFO of a class having more severe condi- 
tions against the delay time at the time of reading 
the cell from the main buffer 103. 

12. A method of constructing a switching system for 
exchanging communication data between a plural- 
ity of incoming highways and a plurafrty of outgoing 
highways by use of a plurality of fixed-length cells 
each having a header section and a data section, 
the system comprising a header drive-type time 
switch for replacing the chronological order of the 
cells in a manner corresporxling to the Incoming 
highways on the basis of the header data, and a 
header drive-type space switch for spatially replac- 
ing a cell between highways on the basis of a single 
header data, each of the outputs of the header 
drive-type time switch being connected to each of 
the header drive-type space switch, said header 
drive-type time switch being the switching system 
according to section 5. 

13. A method of constructing a switching system for 
exchanging the communication data between a plu- 
rality of incoming highways and a plurality of outgo- 
ing highways by use of a plurality of fixed-length 
cells including a header section and a data section, 
the system comprising a header drive-type time 
switch for replacing the chronological order of cells 
in a manner corresponding to the incoming high- 
ways respectively on the basis of the header data, 
and a header drive-type space between the high- 
ways on the basis of a single header data, each of 
the outputs of the header driver-type time switch 
being connected to each of the input terminals of 
the header drive-type space switch, said header 
drive-type time switch being the switching system 
according to section 10. 

Claims 

1. Multi-stage message channel switch for exchang- 
ing communication data between a given number of 
incoming terminals and a given number of outgoing 
terminals, comprising 

a first stage including a plurality of unit switches 
(primary switches) (101 1) each having an inte- 
gral number m of incoming lines, an integral 
number r of outgoing lines and the ratio of 1 to 
X between the incoming line speed and the out- 
going line speed. 

a middle stage including a plurality of unit 
switches (secondary switches) (1021) each 
having an integral number h of incoming lines 
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and an integral number k of outgoing lines, and 
the ratio of 1 to 1 between the incoming line 
speed and the outgoing line speed, and 
a final stage including a plurality of unit 
switches (tertiary switches) (1031) each having 
an integral nunnber r of incoming lines, an inte- 
gral number m of outgoing lines, and the ratio 
of X to 1 between the incoming line speed and 
the outgoing line speed, 
the primary switches (1011) being in the 
number of Is. 

the secondary switches (1021) in the number 
of L and 

the tertiary switches (1031) being in the 
number of k, 

the £ outgoing lines of tiie primary switches 
(1011) being connected to the secondary 
switches (1021) respectively, 
the k outgoing lines of tine secondary switches 
(1021) being connected to the tertiary switches 
(1031) respectively, the relationship 



r 2: 



2 X { ^(m-l)/(x-lp - 1} + I, 



(the symbol 

-(m.l)/(x-ir 

indicates the minimum integral number equal 
to or larger than (m-1)/(x-1) ) being held. 

A multi-stage message channel switch according to 
daim 1 . further comprising a packet (201) including 
a header section and a data section, said cornmuni- 
cation data being exchanged with reference to the 
data contained in the header section of tine packet 
(201). 

A multi-stage message channel switch according to 
daim 1 , wherein r = 2m - 3 and x = 2. 

A multi-stage message channel switch according to 
daim 1. wherein r = m - 2 and x = 3. 
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(54) Multi-stage message channel switch 

(57) The Invention relates to a multi-stage message 
channel switch comprising for exchanging communica- 
tion data between a given number of incoming terminals 
and a given number of outgoing terminals. 

This switch comprises a first stage including a plu- 
rality of unit switches (primary switches) each having an 
integral number oi of incoming lines, an integral number 
r of outgoing lines and the ratio of 1 to x between the 
incoming line speed and the outgoing line speed. 

a middle stage including a plurality of unit switches 
(secondary switches) each having an integral 
number k of incoming lines and an integral number 
k of outgoing lines, and the ratio of 1 to 1 between 
the incoming line speed and the outgoing line 
speed, and 

a final stage including a plurality of unit switches 
(tertiary switches) each having an integral number r 
of incoming lines, an integral number m of outgoing 
lines, and the ratio of x to 1 between the incoming 
line speed and the outgoing line speed. 



the primary switches being in the mimber of fc 

the secondary switches in the number of l and 
the tertiary switches being in the number of k. 
the r outgoing lines of the primary switches being 
connected to the secondary switches respectively, 
the k outgoing lines of the secondary switches 
being connected to the tertiary switches, respec- 
tively, the relationship 



r ^ 



2 X { ^(m.l)/(x.l) - lP+ 1. 



(the symbol 



•(m-l)/(x-l)'» 



indicates the minimum integral number equal to or 
larger than (m-1 )/{x-1 ) ) being held. 
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